package com.shujia.mr.hw.home3;

import org.apache.hadoop.io.LongWritable;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Mapper;

import java.io.IOException;

/**
 * 需求：读取学生基本信息和学生各科成绩，计算各班级中总分排名前三的学生
 *
 * 第一个MR过程
 *
 *      1.需要在Mapper端加载学生的基本信息和学生的各科成绩
 *      2.对信息进行切分，并且有标记信息
 *      3.将学生各科成绩信息进行统计并且关联学生的基本信息
 *      4.将关联的结果写出到结果文件中
 *
 * 第二个MR过程
 *      1.读取第一MR过程的结果
 *      2.分割数据
 *      3.以学生班级信息为Key对数据进行分组
 *      4.对学生的总分进行排序
 *      5.取出其中的前三名
 *
 */
public class Home3Part1Mapper extends Mapper<LongWritable, Text,Text,Text> {
    @Override
    protected void map(LongWritable key, Text value, Mapper<LongWritable, Text, Text, Text>.Context context) throws IOException, InterruptedException {
        String oneLine = value.toString();
        String[] columns = oneLine.split(",");
        if(columns.length == 3){
            // 各科成绩
            context.write(new Text(columns[0]),new Text(columns[2]));
        }else{
            // 基本信息
            context.write(new Text(columns[0]),new Text(columns[1]+","+columns[2]+","+columns[3]+","+columns[4]));
        }
    }
}
